算法 4.4节 Dijkstra算法,拓扑排序算法,bellman-ford算法(暂缺))实现最小路径

// Dijkstra算法
import edu.princeton.cs.algs4.IndexMinPQ;

public class Dijkstra {
    private double[] disTo;
    private Edge[] edgeTo;
    private IndexMinPQ<Double> pq;

    public Dijkstra(EdgeWeightedGraph G, int s) {
        disTo = new double[G.V()];
        edgeTo = new Edge[G.V()];
        pq = new IndexMinPQ<>(G.V());
        for (int v = 0; v< G.V();v++)
            disTo[v] = Double.POSITIVE_INFINITY;
        disTo[s] = 0;
        pq.insert(s, 0.0);

        while (!pq.isEmpty()) {
            relax(G, pq.delMin());
        }
    }

    private void relax(EdgeWeightedGraph G, int s) {
        for (Edge e : G.adj(s)) {
            int w = e.to();
            if (disTo[w] > disTo[s] + e.weight()) {
                disTo[w] = disTo[s] + e.weight();
                edgeTo[w] = e;
                pq.insert(w, disTo[w]);
            }
        }
    }
}
//拓扑排序算法
public class AcyclicSP {
    private double[] disTo;
    private Edge[] edgeTo;

    public AcyclicSP(EdgeWeightedGraph G, int s) {
        disTo = new double[G.V()];
        edgeTo = new Edge[G.V()];
        for (int v = 0; v< G.V();v++)
            disTo[v] = Double.POSITIVE_INFINITY;
        disTo[s] = 0;

        DFSorder order = new DFSorder(G);
        for (int e: order.reversePost()) {
            relax(G, e);
        }
    }

    private void relax(EdgeWeightedGraph G, int s) {
        for (Edge e : G.adj(s)) {
            int w = e.to();
            if (disTo[w] < disTo[s] + e.weight()) {
                disTo[w] = disTo[s] + e.weight();
                edgeTo[w] = e;
            }
        }
    }
}
  • //bellman-ford算法暂缺
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值